package com.useeinfo.oa.modules.wuHanCommon.base.dao;

import com.useeinfo.framework.extend.dao.CrudDao;
import com.useeinfo.framework.sugar.data.QueryParam;
import com.useeinfo.framework.sugar.data.QueryUtils;
import com.useeinfo.framework.sugar.tools.StringConverters;
import com.useeinfo.oa.modules.wuHanCommon.base.entity.WarningDetail;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Repository;

import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.TypedQuery;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@Repository("WarningDetailDao")
public class WarningDetailDao implements CrudDao<WarningDetail> {
    private final static Logger logger = LoggerFactory.getLogger(WarningDetailDao.class);

    @PersistenceContext
    private EntityManager entityManager;

    @Override
    public Map<String, Object> getSearchCondition(Map<String, String> queryHash) {
        Map<String, Object> conditionHash = new HashMap<>();

        conditionHash.put("deleteStatus = ?{paramIndex} ", false);
        if (queryHash == null || queryHash.size() == 0) {
            return conditionHash;
        }

        String userId = queryHash.get("userId");
        if (!StringUtils.isEmpty(userId)) {
            conditionHash.put("and warning.warningGroup.id in(select wu.warningGroup.id from WarningGroupInnerUser wu where wu.systemUser.id = ?{paramIndex} ) ", StringConverters.ToLong(userId));
        }
        return conditionHash;
    }

    @Override
    public Long totalRecord(Map<String, String> queryHash) {
        Map<String, Object> conditions = getSearchCondition(queryHash);
        TypedQuery<Long> typedQuery = QueryUtils.getTypedQueryByCondition("select count(w) from WarningDetail w ", conditions, entityManager, Long.class);
        return typedQuery.getSingleResult();
    }

    @Override
    public List<WarningDetail> findList(QueryParam queryParam) {
        String sqlInfo = queryParam.joinJPQL("select w from WarningDetail w ", "order by w.id desc ");
        Map<String, Object> conditions = getSearchCondition(queryParam.getSqlMap());
        TypedQuery<WarningDetail> typedQuery = QueryUtils.getTypedQueryByCondition(sqlInfo, conditions, entityManager, WarningDetail.class);
        return queryParam.findPageList(typedQuery);
    }

    @Override
    public WarningDetail findModel(Long id) {
        return entityManager.find(WarningDetail.class, id);
    }

    @Override
    public Integer add(WarningDetail model) {
        model.setCreateDate(new Date());
        entityManager.persist(model);
        logger.info("WarningDetailDaoImpl添加WarningDetail成功！");
        return 1;
    }

    @Override
    public Integer update(WarningDetail model) {
        model.setUpdateDate(new Date());
        entityManager.merge(model);
        return 1;
    }

    @Override
    public Integer delete(Long id) {
        WarningDetail warningDetail = entityManager.find(WarningDetail.class, id);
        entityManager.remove(warningDetail);
        return 1;
    }

    @Override
    public Integer deleteLogic(WarningDetail model) {
        return null;
    }


}
